Advanced Debugging
About AdvDbg Consult Train Services Products Tools Community Contact  
欢迎光临 高端调试 登录 | 注册 | FAQ
 
  ACPI调试
Linux内核调试
Windows内核调试
 
  调试战役
调试原理
新工具观察
 
  Linux
Windows Vista
Windows
 
  Linux驱动
WDF
WDM
 
  PCI Express
PCI/PCI-X
USB
无线通信协议
 
  64位CPU
ARM
IA-32
  CPU Info Center
 
  ACPI标准
系统认证
Desktop
服务器
 
  Embedded Linux
嵌入式开发工具
VxWorks
WinCE
嵌入式Windows
 
  格蠹调试套件(GDK)
  格蠹学院
  小朱书店
  老雷的微博
  《软件调试》
  《格蠹汇编》
  《软件调试(第二版)》
沪ICP备11027180号-1

Windows内核

帖子发起人: neil~   发起时间: 2010-01-23 16:38 下午   回复: 4

Print Search
帖子排序:    
   2010-01-23, 16:38 下午
neil 离线,最后访问时间: 2010/1/23 16:28:31 neil~

发帖数前500位
注册: 2010-01-23
发 贴: 3
关于system ptes 的问题
Reply Quote
新手刚刚来:)

有个关于system ptes的问题有点疑惑。
从我的理解来说system ptes就是pte的一种,只不过不是用来描述process的va的,它应该负责是的kernel里面的那些会动态变化的咚咚,但是如果说一个32位的不是pae的系统,2gb的kernel因该是可以用总共2m的pte表来描述了,为什么system ptes要很大呢?

比如随便vm一下,可以看到free 的system ptes还有70121 (应该是page的单位,也就是 280mb左右)

一下子有点糊涂了。希望得到指教。谢谢。

kd> !vm 1

*** Virtual Memory Usage ***
Physical Memory: 262010 ( 1048040 Kb)

************ NO PAGING FILE *********************

Available Pages: 236223 ( 944892 Kb)
ResAvail Pages: 204046 ( 816184 Kb)
Locked IO Pages: 188 ( 752 Kb)
Free System PTEs: 70121 ( 280484 Kb)
IP 地址: 已记录   报告
   2010-01-24, 14:28 下午
Raymond 离线,最后访问时间: 2020/7/3 3:40:25 格蠹老雷

发帖数前10位
注册: 2005-12-19
发 贴: 1,303
Re: 关于system ptes 的问题
Reply Quote
下面这行
Free System PTEs: 70121 ( 280484 Kb)
应该如此解释:
系统中还有70121个系统PTE空闲,这些空闲的PTE可以映射70121个内存页,每个内存页按4KB算,也就是70121*4KB=280484KB内存。

并不是说这些PTE要占用280MB的空间,32位下每个PTE占4个字节,这么多PTE如果使用了,那么会占:
lkd> ? 0n70121*4
Evaluate expression: 280484 = 000447a4
这么多个字节,也就是200多KB,不到1MB的内存空间

IP 地址: 已记录   报告
   2010-01-24, 15:45 下午
neil 离线,最后访问时间: 2010/1/23 16:28:31 neil~

发帖数前500位
注册: 2010-01-23
发 贴: 3
Re: 关于system ptes 的问题
Reply Quote
谢谢raymond,这个也就是让我疑惑的地方,既然pte结构本身所占的空间这么少,为什么系统给我们system ptes这么不大方呢?这些1m/2m的空间,相比paged pool/non-paged pool所占用的几百兆空间,根本是微不足道的。

想不通阿,我觉得理论上32bit,不是pae系统,system ptes给个2m,不就可以来描述2gb的地址了吗?这样就不会有system pte不够的情况了。

还有,system ptes是不是也要被paged pool/non-paged pool/cache用到呢?因为我觉得既然那些是kernel 里面的VA,如果要映射到ram,不可能不通过system pte吧





IP 地址: 已记录   报告
   2010-01-24, 21:26 下午
Raymond 离线,最后访问时间: 2020/7/3 3:40:25 格蠹老雷

发帖数前10位
注册: 2005-12-19
发 贴: 1,303
Re: 关于system ptes 的问题
Reply Quote
Neil,问题是线性地址空间不够用,对于32位系统,内核态的线性地址空间只有0x80000000~0xFFFFFFFF这2GB大,无论是从paged pool、non-paged pool分出来的内存都需要占用这2GB的空间,因此PTE表项多了也没有用,因为线性空间就那么多。
IP 地址: 已记录   报告
   2010-01-25, 00:07 上午
neil 离线,最后访问时间: 2010/1/23 16:28:31 neil~

发帖数前500位
注册: 2010-01-23
发 贴: 3
Re: 关于system ptes 的问题
Reply Quote
有道理:) 谢谢raymond

对了,我还注意到一个地方有点疑惑。通过sysptes命令可以得到ending PTE和starting PTE,我想那么2个减一下然后再除以每个pte的大小,那就可以total system ptes的数量了,可是看起来不是我这么想的

kd> !sysptes

System PTE Information
Total System Ptes 269279
SysPtes list of size 1 has 393 free
SysPtes list of size 2 has 100 free
SysPtes list of size 4 has 31 free
SysPtes list of size 8 has 44 free
SysPtes list of size 16 has 32 free

starting PTE: c0218000
ending PTE: c03def78


free blocks: 2 total free: 70121 largest free block: 49713

kd> ?c03def78-c0218000
Evaluate expression: 1863544 = 001c6f78

kd> ?001c6f78/4 (我是non-pae的系统所以除以4)
Evaluate expression: 465886 = 00071bde

IP 地址: 已记录   报告
高端调试 » 内核探秘 » Windows内核 » 关于system ptes 的问题

 
Legal Notice Privacy Statement Corporate Governance Corporate Governance
(C)2004-2020 ADVDBG.ORG All Rights Reserved.